<template>
  <div class="divBox">
    <el-card class="box-card">
      <div slot="header" class="clearfix">
        <el-steps :active="currentTab" align-center finish-status="success">
          <el-step title="基础信息" />
          <el-step title="TMD记录表" />
          <el-step title="图片/视频" />
          <!--<el-step title="规格设置" />-->
        </el-steps>
      </div>
      <el-form ref="formValidate" v-loading="fullscreenLoading" class="formValidate mt20" :rules="ruleValidate"
        :model="formValidate" label-width="120px" @submit.native.prevent>
        <el-row v-show="currentTab === 0" :gutter="24">
          <!-- 商品信息-->
          <el-col v-bind="grid2">
            <el-form-item label="姓名：" prop="storeName">
              <el-input @change="changePinyin" clearable v-model="formValidate.storeName" maxlength="249" placeholder="请输入"
                :disabled="isDisabled" />
            </el-form-item>
          </el-col>
          <el-col v-bind="grid2">
            <el-form-item label="拼音：" prop="storeName">
              <el-input v-model="formValidate.pyName" clearable maxlength="249" placeholder="请输入姓名" :disabled="true" />
            </el-form-item>
          </el-col>
          <el-col v-bind="grid2">
            <el-form-item label="编号：" prop="storeName">
              <el-input v-model="formValidate.storeName" clearable maxlength="249" placeholder="请输入" :disabled="isDisabled" />
            </el-form-item>
          </el-col>
          <!-- <el-col v-bind="grid2">
            <el-form-item label="姓名：" prop="storeName">
              <el-input
                v-model="formValidate.storeName"
                maxlength="249"
                placeholder="请输入"
                :disabled="isDisabled"
              />
            </el-form-item>
          </el-col> -->
          <el-col v-bind="grid2">

            <el-form-item label="性别：" prop="sex">
              <el-select v-model="formValidate.sex" clearable placeholder="请选择" class="mr20" :disabled="isDisabled"
                style="width:100%;">
                <el-option  key="1" label="男" value="1"></el-option>
                <el-option  key="2" label="女" value="2"></el-option>
              </el-select>
            </el-form-item>
          </el-col>
          <el-col v-bind="grid2">
            <el-form-item label="出生日期：" prop="age">
              <el-date-picker v-model="formValidate.age" clearable type="date" value-format="yyyy-MM-dd" format="yyyy-MM-dd" @change="getAge"
                placeholder="选择日期">
              </el-date-picker>
              {{ formValidate.ages }} <span v-if="formValidate.ages">岁</span>
            </el-form-item>
          </el-col>


          <el-col :xs="18" :sm="18" :md="18" :lg="12" :xl="12">
            <el-form-item label="类别：" prop="tempId">
              <el-select v-model="formValidate.tempId" clearable placeholder="请选择" class="mr20" :disabled="isDisabled"
                style="width:100%;">
                <el-option v-for="item in shippingList" :key="item.id" :label="item.name" :value="item.id" />
              </el-select>
            </el-form-item>
          </el-col>
          <el-col v-bind="grid2">
            <el-form-item label="手机号码：" prop="storeInfo">
              <el-input v-model="formValidate.storeInfo" clearable maxlength="250" :rows="3" placeholder="请输入"
                :disabled="isDisabled" />
            </el-form-item>
          </el-col>



          <el-col :xs="18" :sm="18" :md="18" :lg="12" :xl="12">
            <el-form-item label="来源：" prop="tempId">
              <el-select v-model="formValidate.tempId" clearable placeholder="请选择" class="mr20" :disabled="isDisabled"
                style="width:100%;">
                <el-option v-for="item in shippingList" :key="item.id" :label="item.name" :value="item.id" />
              </el-select>
            </el-form-item>
          </el-col>
          <el-col :xs="18" :sm="18" :md="18" :lg="12" :xl="12">
            <el-form-item label="备注：" prop="tempId">
              <el-input v-model="formValidate.storeInfo" clearable type="textarea" maxlength="250" :rows="3" placeholder="请输入"
                :disabled="isDisabled" />
            </el-form-item>
          </el-col>

        </el-row>
        <!-- 商品详情-->
        <el-row v-show="currentTab === 1 && !isDisabled">
          <el-col :span="24">
            <TMDForm></TMDForm>
          </el-col>
        </el-row>
        <el-row v-show="currentTab === 1 && isDisabled">
          <el-col :span="24">
            <el-form-item label="2商品详情：">
              <span v-html="formValidate.content || '无'"></span>
            </el-form-item>
          </el-col>
        </el-row>
        <!-- 其他设置-->
        <el-row v-show="currentTab === 2">
          <el-col :span="24">
            <el-col v-bind="grid">
              <el-form-item label="口扫文件上传(仅支持STL格式)：">
                <ImageUpload></ImageUpload>
              </el-form-item>
            </el-col>
            <el-col :span="24">
              <el-form-item label="CT文件上传：">
                <ImageUpload></ImageUpload>
              </el-form-item>
            </el-col>
            <el-col :span="24">
              <el-form-item label="核磁文件上传：">
                <ImageUpload></ImageUpload>
              </el-form-item>
            </el-col>
            <el-col :span="24">
              <el-form-item label="治疗照片上传：">
                <ImageUpload></ImageUpload>
              </el-form-item>
            </el-col>

          </el-col>
        </el-row>
        <el-form-item>
          <el-button v-show="currentTab > 0" class="submission priamry_border" @click="handleSubmitUp">上一步</el-button>
          <el-button v-show="currentTab < 2" type="primary" class="submission"
            @click="handleSubmitNest('formValidate')">下一步</el-button>
          <el-button v-show="(currentTab === 2 || $route.params.id) && !isDisabled" type="primary" class="submission"
            @click="handleSubmit('formValidate')">提交</el-button>
            <el-button v-show="(currentTab === 2 || $route.params.id) && !isDisabled" type="primary" class="submission"
            @click="handleSubmitReport('formValidate')">生成诊断报告</el-button>

        </el-form-item>
      </el-form>
    </el-card>
    <CreatTemplates ref="addTemplates" @getList="getShippingList" />
  </div>
</template>

<script>
// import ImageUpload from '@/components/ImageUpload/index'
import TMDForm from '@/views/doctor/patient/com/addPerson/TMDForm'
import Pinyin from "js-pinyin";
// import Tinymce from "@/components/Tinymce/index";
// import {
//   templateListApi,
//   productCreateApi,
//   categoryApi,
//   productDetailApi,
//   productUpdateApi
// } from "@/api/store";
// import { marketingSendApi } from "@/api/marketing";
// import { shippingTemplatesList } from "@/api/logistics";
// import { goodDesignList } from "@/api/systemGroup";
// import { clearTreeData } from "@/utils/ZBKJIutil";
// import CreatTemplates from "@/views/systemSetting/logistics/shippingTemplates/creatTemplates";
// import Templates from "../../appSetting/wxAccount/wxTemplate/index";
// import { Debounce } from "@/utils/validate";
const defaultObj = {
  pyName: '',
  image: "",
  sliderImages: [],
  videoLink: "",
  sliderImage: "",
  storeName: "",
  storeInfo: "",
  age: "",
  ages: "",
  sex: [], // 商品分类id
  cateId: null, // 商品分类id传值
  unitName: "",
  sort: 0,
  giveIntegral: 0,
  ficti: 0,
  isShow: false,
  isBenefit: false,
  isNew: false,
  isIntegral: false,
  isGood: false,
  isHot: false,
  isBest: false,
  tempId: "",
  attrValue: [
    {
      image: "",
      price: 0,
      cost: 0,
      otPrice: 0,
      stock: 0,
      barCode: "",
      weight: 0,
      volume: 0
    }
  ],
  attr: [],
  selectRule: "",
  isSub: false,
  content: "",
  specType: false,
  id: 0,
  couponIds: [],
  coupons: [],
  activity: ["默认", "秒杀", "砍价", "拼团"]
};
const objTitle = {
  price: {
    title: "售价"
  },
  cost: {
    title: "成本价"
  },
  otPrice: {
    title: "原价"
  },
  stock: {
    title: "库存"
  },
  barCode: {
    title: "商品编号"
  },
  weight: {
    title: "重量（KG）"
  },
  volume: {
    title: "体积(m³)"
  }
};
export default {
  name: "ProductProductAdd",
  components: { TMDForm },
  data() {
    return {
      age: null,
      isDisabled: this.$route.params.isDisabled === "1" ? true : false,
      activity: { 默认: "red", 秒杀: "blue", 砍价: "green", 拼团: "yellow" },
      props2: {
        children: "child",
        label: "name",
        value: "id",
        multiple: true,
        emitPath: false
      },
      checkboxGroup: [],
      recommend: [],
      tabs: [],
      fullscreenLoading: false,
      props: { multiple: true },
      active: 0,
      OneattrValue: [Object.assign({}, defaultObj.attrValue[0])], // 单规格
      ManyAttrValue: [Object.assign({}, defaultObj.attrValue[0])], // 多规格
      ruleList: [],
      merCateList: [], // 商户分类筛选
      shippingList: [
        {
          name: '张三',
          id: 1
        }
      ], // 运费模板
      formThead: Object.assign({}, objTitle),
      formValidate: Object.assign({}, defaultObj),
      formDynamics: {
        ruleName: "",
        ruleValue: []
      },
      tempData: {
        page: 1,
        limit: 9999
      },
      manyTabTit: {},
      manyTabDate: {},
      grid2: {
        xl: 12,
        lg: 12,
        md: 12,
        sm: 24,
        xs: 24
      },
      // 规格数据
      formDynamic: {
        attrsName: "",
        attrsVal: ""
      },
      isBtn: false,
      manyFormValidate: [],
      currentTab: 1,
      isChoice: "",
      grid: {
        xl: 8,
        lg: 8,
        md: 12,
        sm: 24,
        xs: 24
      },
      ruleValidate: {
        storeName: [
          { required: true, message: "请输入", trigger: "blur" }
        ],

        sex: [
          { required: true, message: "请选择", trigger: "blur" }
        ],
        age: [
          { required: true, message: "请选择", trigger: "blur" }
        ],
        unitName: [{ required: true, message: "请输入", trigger: "blur" }],
        storeInfo: [
          { required: true, message: "请输入", trigger: "blur" }
        ],
        tempId: [
          { required: true, message: "请选择", trigger: "change" }
        ],
        image: [{ required: true, message: "请上传", trigger: "change" }],
        sliderImages: [
          {
            required: true,
            message: "请上传",
            type: "array",
            trigger: "change"
          }
        ],
        specType: [
          { required: true, message: "请选择", trigger: "change" }
        ]
      },
      attrInfo: {},
      tableFrom: {
        page: 1,
        limit: 9999,
        keywords: ""
      },
      tempRoute: {},
      keyNum: 0,
      isAttr: false,
      showAll: false,
      videoLink: ""
    };
  },
  computed: {
    attrValue() {
      const obj = Object.assign({}, defaultObj.attrValue[0]);
      delete obj.image;
      return obj;
    },
    oneFormBatch() {
      const obj = [Object.assign({}, defaultObj.attrValue[0])];
      delete obj[0].barCode;
      return obj;
    }
  },
  watch: {
    "formValidate.attr": {
      handler: function (val) {
        if (this.formValidate.specType && this.isAttr) this.watCh(val); //重要！！！
      },
      immediate: false,
      deep: true
    }
  },
  created() {
    this.tempRoute = Object.assign({}, this.$route);
    if (this.$route.params.id && this.formValidate.specType) {
      this.$watch("formValidate.attr", this.watCh);
    }
  },
  mounted() {
    this.formValidate.sliderImages = [];
    if (this.$route.params.id) {
      this.setTagsViewTitle();
      this.getInfo();
    }
    this.getCategorySelect();
    this.getShippingList();
    this.getGoodsType();
  },
  methods: {
    // 根据出生日期获取年龄
    getAge(vl) {

      if (vl) {
        let birthdays = new Date(vl.replace(/-/g, "/"));
        let d = new Date();
        let age =
          d.getFullYear() -
          birthdays.getFullYear() -
          (d.getMonth() < birthdays.getMonth() ||
            (d.getMonth() == birthdays.getMonth() &&
              d.getDate() < birthdays.getDate())
            ? 1
            : 0);
        // console.log(age, 'ageage')
        this.formValidate.ages = age;
      }
    },

    changePinyin() {


      this.formValidate.pyName = Pinyin.getFullChars(this.formValidate.storeName)

    },

    // 校验输入框不能输入0，保留2位小数，库存为正整数
    keyupEvent(key, val, index, num) {
      if (key === "barCode") return;
      var re = /^\D*([0-9]\d*\.?\d{0,2})?.*$/;
      switch (num) {
        case 1:
          if (val == 0) {
            this.oneFormBatch[index][key] = key === "stock" ? 0 : 0.01;
          } else {
            this.oneFormBatch[index][key] =
              key === "stock"
                ? parseInt(val)
                : this.$set(
                  this.oneFormBatch[index],
                  key,
                  val.toString().replace(re, "$1")
                );
          }
          break;
        case 2:
          if (val == 0) {
            this.OneattrValue[index][key] = key === "stock" ? 0 : 0.01;
          } else {
            this.OneattrValue[index][key] =
              key === "stock"
                ? parseInt(val)
                : this.$set(
                  this.OneattrValue[index],
                  key,
                  val.toString().replace(re, "$1")
                );
          }
          break;
        default:
          if (val == 0) {
            this.ManyAttrValue[index][key] = key === "stock" ? 0 : 0.01;
          } else {
            this.ManyAttrValue[index][key] =
              key === "stock"
                ? parseInt(val)
                : this.$set(
                  this.ManyAttrValue[index],
                  key,
                  val.toString().replace(re, "$1")
                );
          }
          break;
      }
    },
    handleCloseCoupon(tag) {
      this.isAttr = true;
      this.formValidate.coupons.splice(
        this.formValidate.coupons.indexOf(tag),
        1
      );
      this.formValidate.couponIds.splice(
        this.formValidate.couponIds.indexOf(tag.id),
        1
      );
    },
    addCoupon() {
      const _this = this;
      this.$modalCoupon(
        "wu",
        (this.keyNum += 1),
        this.formValidate.coupons,
        function (row) {
          _this.formValidate.couponIds = [];
          _this.formValidate.coupons = row;
          row.map(item => {
            _this.formValidate.couponIds.push(item.id);
          });
        },
        ""
      );
    },
    setTagsViewTitle() {
      const title = this.isDisabled ? "商品详情" : "编辑商品";
      const route = Object.assign({}, this.tempRoute, {
        title: `${title}-${this.$route.params.id}`
      });
      this.$store.dispatch("tagsView/updateVisitedView", route);
    },
    onChangeGroup() {
      this.checkboxGroup.includes("isGood")
        ? (this.formValidate.isGood = true)
        : (this.formValidate.isGood = false);
      this.checkboxGroup.includes("isBenefit")
        ? (this.formValidate.isBenefit = true)
        : (this.formValidate.isBenefit = false);
      this.checkboxGroup.includes("isBest")
        ? (this.formValidate.isBest = true)
        : (this.formValidate.isBest = false);
      this.checkboxGroup.includes("isNew")
        ? (this.formValidate.isNew = true)
        : (this.formValidate.isNew = false);
      this.checkboxGroup.includes("isHot")
        ? (this.formValidate.isHot = true)
        : (this.formValidate.isHot = false);
      this.checkboxGroup.includes("isIntegral")
        ? (this.formValidate.isIntegral = true)
        : (this.formValidate.isIntegral = false);
    },
    watCh(val) {
      const tmp = {};
      const tmpTab = {};
      this.formValidate.attr.forEach((o, i) => {
        // tmp['value' + i] = { title: o.attrName }
        // tmpTab['value' + i] = ''
        tmp[o.attrName] = { title: o.attrName };
        tmpTab[o.attrName] = "";
      });
      this.ManyAttrValue = this.attrFormat(val);
      this.ManyAttrValue.forEach((val, index) => {
        const key = Object.values(val.attrValue)
          .sort()
          .join("/");
        if (this.attrInfo[key]) this.ManyAttrValue[index] = this.attrInfo[key];
      });
      this.attrInfo = [];
      this.ManyAttrValue.forEach(val => {
        this.attrInfo[
          Object.values(val.attrValue)
            .sort()
            .join("/")
        ] = val;
      });
      this.manyTabTit = tmp;
      this.manyTabDate = tmpTab;
      this.formThead = Object.assign({}, this.formThead, tmp);
    },
    attrFormat(arr) {
      let data = [];
      const res = [];
      return format(arr);
      function format(arr) {
        if (arr.length > 1) {
          arr.forEach((v, i) => {
            if (i === 0) data = arr[i]["attrValue"];
            const tmp = [];
            if (!data) return;
            data.forEach(function (vv) {
              arr[i + 1] &&
                arr[i + 1]["attrValue"] &&
                arr[i + 1]["attrValue"].forEach(g => {
                  const rep2 =
                    (i !== 0 ? "" : arr[i]["attrName"] + "_") +
                    vv +
                    "$&" +
                    arr[i + 1]["attrName"] +
                    "_" +
                    g;
                  tmp.push(rep2);
                  if (i === arr.length - 2) {
                    const rep4 = {
                      image: "",
                      price: 0,
                      cost: 0,
                      otPrice: 0,
                      stock: 0,
                      barCode: "",
                      weight: 0,
                      volume: 0,
                      brokerage: 0,
                      brokerage_two: 0
                    };
                    rep2.split("$&").forEach((h, k) => {
                      const rep3 = h.split("_");
                      if (!rep4["attrValue"]) rep4["attrValue"] = {};
                      rep4["attrValue"][rep3[0]] =
                        rep3.length > 1 ? rep3[1] : "";
                    });
                    for (let attrValueKey in rep4.attrValue) {
                      rep4[attrValueKey] = rep4.attrValue[attrValueKey];
                    }
                    res.push(rep4);
                  }
                });
            });
            data = tmp.length ? tmp : [];
          });
        } else {
          const dataArr = [];
          arr.forEach((v, k) => {
            v["attrValue"].forEach((vv, kk) => {
              dataArr[kk] = v["attrName"] + "_" + vv;
              res[kk] = {
                image: "",
                price: 0,
                cost: 0,
                otPrice: 0,
                stock: 0,
                barCode: "",
                weight: 0,
                volume: 0,
                brokerage: 0,
                brokerage_two: 0,
                attrValue: { [v["attrName"]]: vv }
              };
              // Object.values(res[kk].attrValue).forEach((v, i) => {
              //   res[kk]['value' + i] = v
              // })
              for (let attrValueKey in res[kk].attrValue) {
                res[kk][attrValueKey] = res[kk].attrValue[attrValueKey];
              }
            });
          });
          data.push(dataArr.join("$&"));
        }
        return res;
      }
    },
    // 运费模板
    addTem() {
      this.$refs.addTemplates.dialogVisible = true;
      this.$refs.addTemplates.getCityList();
    },
    // 添加规则；
    addRule() {
      const _this = this;
      this.$modalAttr(this.formDynamics, function () {
        _this.productGetRule();
      });
    },
    // 选择规格
    onChangeSpec(num) {
      this.isAttr = true;
      if (num) this.productGetRule();
    },
    // 选择属性确认
    confirm() {
      this.isAttr = true;
      if (!this.formValidate.selectRule) {
        return this.$message.warning("请选择属性");
      }
      const data = [];
      this.ruleList.forEach(item => {
        if (item.id === this.formValidate.selectRule) {
          item.ruleValue.forEach(i => {
            data.push({
              attrName: i.value,
              attrValue: i.detail
            });
          });
        }
        this.formValidate.attr = data;
      });
    },
    // 商品分类；
    getCategorySelect() {
      categoryApi({ status: -1, type: 1 }).then(res => {
        this.merCateList = this.filerMerCateList(res);
        let newArr = [];
        res.forEach((value, index) => {
          newArr[index] = value;
          if (value.child)
            newArr[index].child = value.child.filter(
              item => item.status === true
            );
        }); //过滤商品分类设置为隐藏的子分类不出现在树形列表里
        this.merCateList = this.filerMerCateList(newArr);
      });
    },
    filerMerCateList(treeData) {
      return treeData.map(item => {
        if (!item.child) {
          item.disabled = true;
        }
        item.label = item.name;
        return item;
      });
    },
    // 获取商品属性模板；
    productGetRule() {
      templateListApi(this.tableFrom).then(res => {
        const list = res.list;
        for (var i = 0; i < list.length; i++) {
          list[i].ruleValue = JSON.parse(list[i].ruleValue);
        }
        this.ruleList = list;
      });
    },
    // 运费模板；
    getShippingList() {
      shippingTemplatesList(this.tempData).then(res => {
        this.shippingList = res.list;
      });
    },
    showInput(item) {
      this.$set(item, "inputVisible", true);
    },
    onChangetype(item) {
      if (item === 1) {
        this.OneattrValue.map(item => {
          this.$set(item, "brokerage", null);
          this.$set(item, "brokerageTwo", null);
        });
        this.ManyAttrValue.map(item => {
          this.$set(item, "brokerage", null);
          this.$set(item, "brokerageTwo", null);
        });
      } else {
        this.OneattrValue.map(item => {
          delete item.brokerage;
          delete item.brokerageTwo;
          this.$set(item, "brokerage", null);
          this.$set(item, "brokerageTwo", null);
        });
        this.ManyAttrValue.map(item => {
          delete item.brokerage;
          delete item.brokerageTwo;
        });
      }
    },
    // 删除表格中的属性
    delAttrTable(index) {
      this.ManyAttrValue.splice(index, 1);
    },
    // 批量添加
    batchAdd() {
      // if (!this.oneFormBatch[0].pic || !this.oneFormBatch[0].price || !this.oneFormBatch[0].cost || !this.oneFormBatch[0].ot_price ||
      //     !this.oneFormBatch[0].stock || !this.oneFormBatch[0].bar_code) return this.$Message.warning('请填写完整的批量设置内容！');
      for (const val of this.ManyAttrValue) {
        this.$set(val, "image", this.oneFormBatch[0].image);
        this.$set(val, "price", this.oneFormBatch[0].price);
        this.$set(val, "cost", this.oneFormBatch[0].cost);
        this.$set(val, "otPrice", this.oneFormBatch[0].otPrice);
        this.$set(val, "stock", this.oneFormBatch[0].stock);
        this.$set(val, "barCode", this.oneFormBatch[0].barCode);
        this.$set(val, "weight", this.oneFormBatch[0].weight);
        this.$set(val, "volume", this.oneFormBatch[0].volume);
        this.$set(val, "brokerage", this.oneFormBatch[0].brokerage);
        this.$set(val, "brokerageTwo", this.oneFormBatch[0].brokerageTwo);
      }
    },
    // 添加按钮
    addBtn() {
      this.clearAttr();
      this.isBtn = true;
    },
    // 取消
    offAttrName() {
      this.isBtn = false;
    },
    clearAttr() {
      this.isAttr = true;
      this.formDynamic.attrsName = "";
      this.formDynamic.attrsVal = "";
    },
    // 删除规格
    handleRemoveAttr(index) {
      this.isAttr = true;
      this.formValidate.attr.splice(index, 1);
      this.manyFormValidate.splice(index, 1);
    },
    // 删除属性
    handleClose(item, index) {
      item.splice(index, 1);
    },
    // 添加规则名称
    createAttrName() {
      this.isAttr = true;
      if (this.formDynamic.attrsName && this.formDynamic.attrsVal) {
        const data = {
          attrName: this.formDynamic.attrsName,
          attrValue: [this.formDynamic.attrsVal]
        };
        this.formValidate.attr.push(data);
        var hash = {};
        this.formValidate.attr = this.formValidate.attr.reduce(function (
          item,
          next
        ) {
          /* eslint-disable */
          hash[next.attrName]
            ? ""
            : (hash[next.attrName] = true && item.push(next));
          return item;
        },
          []);
        this.clearAttr();
        this.isBtn = false;
      } else {
        this.$Message.warning("请添加完整的规格！");
      }
    },
    // 添加属性
    createAttr(num, idx) {
      this.isAttr = true;
      if (num) {
        this.formValidate.attr[idx].attrValue.push(num);
        var hash = {};
        this.formValidate.attr[idx].attrValue = this.formValidate.attr[
          idx
        ].attrValue.reduce(function (item, next) {
          /* eslint-disable */
          hash[next] ? "" : (hash[next] = true && item.push(next));
          return item;
        }, []);
        this.formValidate.attr[idx].inputVisible = false;
      } else {
        this.$message.warning("请添加属性");
      }
    },
    //点击展示所有多规格属性
    showAllSku() {
      if (this.isAttr == false) {
        this.isAttr = true;
        if (this.formValidate.specType && this.isAttr)
          this.watCh(this.formValidate.attr); //重要！！！
      } else if (this.isAttr == true) {
        this.isAttr = false;
        this.getInfo();
      }
    },
    // 详情
    getInfo() {
      this.fullscreenLoading = true;
      productDetailApi(this.$route.params.id)
        .then(async res => {
          // this.isAttr = true;
          let info = res;
          this.formValidate = {
            pyName: info.storeName,
            image: this.$selfUtil.setDomain(info.image),
            sliderImage: info.sliderImage,
            sliderImages: JSON.parse(info.sliderImage),
            storeName: info.storeName,
            storeInfo: info.storeInfo,
            age: info.age,
            ages: info.ages,

            sex: info.cateId.split(","), // 商品分类id
            cateId: info.cateId, // 商品分类id传值
            unitName: info.unitName,
            sort: info.sort,
            isShow: info.isShow,
            isBenefit: info.isBenefit,
            isNew: info.isNew,
            isIntegral: info.isIntegral,
            isGood: info.isGood,
            isHot: info.isHot,
            isBest: info.isBest,
            tempId: info.tempId,
            attr: info.attr,
            attrValue: info.attrValue,
            selectRule: info.selectRule,
            isSub: info.isSub,
            content: this.$selfUtil.replaceImgSrcHttps(info.content),
            specType: info.specType,
            id: info.id,
            giveIntegral: info.giveIntegral,
            ficti: info.ficti,
            coupons: info.coupons,
            couponIds: info.couponIds,
            activity: info.activityStr
              ? info.activityStr.split(",")
              : ["默认", "秒杀", "砍价", "拼团"]
          };
          marketingSendApi({ type: 3 }).then(res => {
            if (this.formValidate.couponIds !== null) {
              let ids = this.formValidate.couponIds.toString();
              let arr = res.list;
              let obj = {};
              for (let i in arr) {
                obj[arr[i].id] = arr[i];
              }
              let strArr = ids.split(",");
              let newArr = [];
              for (let item of strArr) {
                if (obj[item]) {
                  newArr.push(obj[item]);
                }
              }
              this.$set(this.formValidate, "coupons", newArr); //在编辑回显时，让返回数据中的优惠券id，通过接口匹配显示,
            }
          });
          let imgs = JSON.parse(info.sliderImage);
          let imgss = [];
          Object.keys(imgs).map(i => {
            imgss.push(this.$selfUtil.setDomain(imgs[i]));
          });
          this.formValidate.sliderImages = [...imgss];
          if (info.isHot) this.checkboxGroup.push("isHot");
          if (info.isGood) this.checkboxGroup.push("isGood");
          if (info.isBenefit) this.checkboxGroup.push("isBenefit");
          if (info.isBest) this.checkboxGroup.push("isBest");
          if (info.isNew) this.checkboxGroup.push("isNew");
          if (info.isIntegral) this.checkboxGroup.push("isIntegral");
          this.productGetRule();
          if (info.specType) {
            this.formValidate.attr = info.attr.map(item => {
              return {
                attrName: item.attrName,
                attrValue: item.attrValues.split(",")
              };
            });
            this.ManyAttrValue = info.attrValue;
            this.ManyAttrValue.forEach(val => {
              val.image = this.$selfUtil.setDomain(val.image);
              val.attrValue = JSON.parse(val.attrValue);
              this.attrInfo[
                Object.values(val.attrValue)
                  .sort()
                  .join("/")
              ] = val;
            });
            /***多规格商品如果被删除过sku，优先展示api返回的数据,否则会有没有删除的错觉***/
            let manyAttr = this.attrFormat(this.formValidate.attr);
            if (manyAttr.length !== this.ManyAttrValue.length) {
              this.$set(this, "showAll", true);
              this.isAttr = false;
            } else {
              this.isAttr = true;
            }
            /*******/
            const tmp = {};
            const tmpTab = {};
            this.formValidate.attr.forEach((o, i) => {
              // tmp['value' + i] = { title: o.attrName }
              // tmpTab['value' + i] = ''
              tmp[o.attrName] = { title: o.attrName };
              tmpTab[o.attrName] = "";
            });

            // 此处手动实现后台原本value0 value1的逻辑
            this.formValidate.attrValue.forEach(item => {
              for (let attrValueKey in item.attrValue) {
                item[attrValueKey] = item.attrValue[attrValueKey];
              }
            });

            this.manyTabTit = tmp;
            this.manyTabDate = tmpTab;
            this.formThead = Object.assign({}, this.formThead, tmp);
          } else {
            this.OneattrValue = info.attrValue;
            // this.formValidate.attr = [] //单规格商品规格设置为空
          }
          this.fullscreenLoading = false;
        })
        .catch(res => {
          this.fullscreenLoading = false;
          this.$message.error(res.message);
        });
    },
    handleRemove(i) {
      this.formValidate.sliderImages.splice(i, 1);
    },
    // 点击商品图
    modalPicTap(tit, num, i, status) {
      const _this = this;
      if (_this.isDisabled) return;
      this.$modalUpload(
        function (img) {
          if (tit === "1" && !num) {
            _this.formValidate.image = img[0].sattDir;
            _this.OneattrValue[0].image = img[0].sattDir;
          }
          if (tit === "2" && !num) {
            if (img.length > 10)
              return this.$message.warning("最多选择10张图片！");
            if (img.length + _this.formValidate.sliderImages.length > 10)
              return this.$message.warning("最多选择10张图片！");
            img.map(item => {
              _this.formValidate.sliderImages.push(item.sattDir);
            });
          }
          if (tit === "1" && num === "dan") {
            _this.OneattrValue[0].image = img[0].sattDir;
          }
          if (tit === "1" && num === "duo") {
            _this.ManyAttrValue[i].image = img[0].sattDir;
          }
          if (tit === "1" && num === "pi") {
            _this.oneFormBatch[0].image = img[0].sattDir;
          }
        },
        tit,
        "content"
      );
    },
    handleSubmitUp() {
      // this.currentTab --
      if (this.currentTab-- < 0) this.currentTab = 0;
    },
    handleSubmitReport(){
      let id=1
      this.$router.push({ path: "TMDForm", query: { id: id,type:"问卷调查" } });
         console.log('调查问卷')
    },
    handleSubmitNest(name) {
      if (this.currentTab++ > 2) this.currentTab = 0;
      return;
      this.$refs[name].validate(valid => {
        if (valid) {
          if (this.currentTab++ > 2) this.currentTab = 0;
        } else {
          if (
            !this.formValidate.store_name ||
            !this.formValidate.cate_id ||
            !this.formValidate.age ||
            !this.formValidate.unit_name ||
            !this.formValidate.store_info ||
            !this.formValidate.image ||
            !this.formValidate.slider_image
          ) {
            this.$message.warning("请填写完整商品信息！");
          }
        }
      });
    },
    // 提交
    handleSubmit() {

    },
    // handleSubmit (name) {
    //   this.onChangeGroup();
    //   if (this.formValidate.specType && this.formValidate.attr.length < 1)
    //     return this.$message.warning("请填写多规格属性！");
    //   this.formValidate.cateId = this.formValidate.cateIds.join(",");
    //   this.formValidate.sliderImage = JSON.stringify(
    //     this.formValidate.sliderImages
    //   );
    //   if (this.formValidate.specType) {
    //     this.formValidate.attrValue = this.ManyAttrValue;
    //     this.formValidate.attr = this.formValidate.attr.map(item => {
    //       return {
    //         attrName: item.attrName,
    //         id: item.id,
    //         attrValues: item.attrValue.join(",")
    //       };
    //     });
    //     for (var i = 0; i < this.formValidate.attrValue.length; i++) {
    //       this.$set(this.formValidate.attrValue[i], "id", 0);
    //       this.$set(this.formValidate.attrValue[i], "productId", 0);
    //       this.$set(
    //         this.formValidate.attrValue[i],
    //         "attrValue",
    //         JSON.stringify(this.formValidate.attrValue[i].attrValue)
    //       ); //
    //       delete this.formValidate.attrValue[i].value0;
    //     }
    //   } else {
    //     this.formValidate.attr = [
    //       {
    //         attrName: "规格",
    //         attrValues: "默认",
    //         id: this.$route.params.id ? this.formValidate.attr[0].id : 0
    //       }
    //     ];
    //     this.OneattrValue.map(item => {
    //       this.$set(item, "attrValue", JSON.stringify({ 规格: "默认" }));
    //     });
    //     this.formValidate.attrValue = this.OneattrValue;
    //   }
    //   this.$refs[name].validate(valid => {
    //     if (valid) {
    //       this.fullscreenLoading = true;
    //       this.$route.params.id
    //         ? productUpdateApi(this.formValidate)
    //             .then(async res => {
    //               this.$message.success("编辑成功");
    //               setTimeout(() => {
    //                 this.$router.push({ path: "/store/index" });
    //               }, 500);
    //               this.fullscreenLoading = false;
    //             })
    //             .catch(res => {
    //               this.fullscreenLoading = false;
    //             })
    //         : productCreateApi(this.formValidate)
    //             .then(async res => {
    //               this.$message.success("新增成功");
    //               setTimeout(() => {
    //                 this.$router.push({ path: "/store/index" });
    //               }, 500);
    //               this.fullscreenLoading = false;
    //             })
    //             .catch(res => {
    //               this.fullscreenLoading = false;
    //             });
    //     } else {
    //       if (
    //         !this.formValidate.storeName ||
    //         !this.formValidate.cateId ||
    //         !this.formValidate.keyword ||
    //         !this.formValidate.unitName ||
    //         !this.formValidate.storeInfo ||
    //         !this.formValidate.image ||
    //         !this.formValidate.sliderImages
    //       ) {
    //         this.$message.warning("请填写完整商品信息！");
    //       }
    //     }
    //   });
    // }),
    // 表单验证
    validate(prop, status, error) {
      if (status === false) {
        this.$message.warning(error);
      }
    },
    // 移动
    handleDragStart(e, item) {
      if (!this.isDisabled) this.dragging = item;
    },
    handleDragEnd(e, item) {
      if (!this.isDisabled) this.dragging = null;
    },
    handleDragOver(e) {
      if (!this.isDisabled) e.dataTransfer.dropEffect = "move";
    },
    handleDragEnter(e, item) {
      if (!this.isDisabled) {
        e.dataTransfer.effectAllowed = "move";
        if (item === this.dragging) {
          return;
        }
        const newItems = [...this.formValidate.sliderImages];
        const src = newItems.indexOf(this.dragging);
        const dst = newItems.indexOf(item);
        newItems.splice(dst, 0, ...newItems.splice(src, 1));
        this.formValidate.sliderImages = newItems;
      }
    },
    handleDragEnterFont(e, item) {
      if (!this.isDisabled) {
        e.dataTransfer.effectAllowed = "move";
        if (item === this.dragging) {
          return;
        }
        const newItems = [...this.formValidate.activity];
        const src = newItems.indexOf(this.dragging);
        const dst = newItems.indexOf(item);
        newItems.splice(dst, 0, ...newItems.splice(src, 1));
        this.formValidate.activity = newItems;
      }
    },
    getGoodsType() {
      /** 让商品推荐列表的name属性与页面设置tab的name匹配**/
      goodDesignList({ gid: 70 }).then(response => {
        let list = response.list;
        let arr = [],
          arr1 = [];
        const listArr = [];
        let typeLists = [
          // { name: "", value: "isHot", type: "2" }, //热门榜单
          // { name: "", value: "isBenefit", type: "4" }, //促销单品
          // { name: "", value: "isBest", type: "1" }, //精品推荐
          // { name: "", value: "isNew", type: "3" }, //首发新品
          { name: "", value: "isIntegral", type: "5" }
        ]; //是否支持积分兑换
        list.forEach(item => {
          let obj = {};
          obj.value = JSON.parse(item.value);
          obj.id = item.id;
          obj.gid = item.gid;
          obj.status = item.status;
          arr.push(obj);
        });
        arr.forEach(item1 => {
          let obj1 = {};
          obj1.name = item1.value.fields[1].value;
          obj1.status = item1.status;
          obj1.type = item1.value.fields[3].value;
          arr1.push(obj1);
        });
        typeLists.forEach(item => {
          arr1.forEach(item1 => {
            if (item.type == item1.type) {
              listArr.push({
                name: item1.name,
                value: item.value,
                type: item.type
              });
            }
          });
        });
        this.recommend = listArr;
      });
    }
  }
};
</script>
<style scoped lang="scss">
.disLabel {
  ::v-deep.el-form-item__label {
    margin-left: 36px !important;
  }
}

.disLabelmoren {
  ::v-deep.el-form-item__label {
    margin-left: 120px !important;
  }
}

.priamry_border {
  border: 1px solid #1890ff;
  color: #1890ff;
}

.color-item {
  height: 30px;
  line-height: 30px;
  padding: 0 10px;
  color: #fff;
  margin-right: 10px;
}

.color-list .color-item.blue {
  background-color: #1e9fff;
}

.color-list .color-item.yellow {
  background-color: rgb(254, 185, 0);
}

.color-list .color-item.green {
  background-color: #009688;
}

.color-list .color-item.red {
  background-color: #ed4014;
}

.proCoupon {
  ::v-deep.el-form-item__content {
    margin-top: 5px;
  }
}

.tabPic {
  width: 40px !important;
  height: 40px !important;

  img {
    width: 100%;
    height: 100%;
  }
}

.noLeft {
  ::v-deep.el-form-item__content {
    margin-left: 0 !important;
  }
}

.tabNumWidth {
  ::v-deep.el-input-number--medium {
    width: 121px !important;
  }

  ::v-deep.el-input-number__increase {
    width: 20px !important;
    font-size: 12px !important;
  }

  ::v-deep.el-input-number__decrease {
    width: 20px !important;
    font-size: 12px !important;
  }

  ::v-deep.el-input-number--medium .el-input__inner {
    padding-left: 25px !important;
    padding-right: 25px !important;
  }

  ::v-deep thead {
    line-height: normal !important;
  }

  ::v-deep .el-table .cell {
    line-height: normal !important;
  }
}

.selWidth {
  width: 100%;
}

.selWidthd {
  width: 300px;
}

.button-new-tag {
  height: 28px;
  line-height: 26px;
  padding-top: 0;
  padding-bottom: 0;
}

.input-new-tag {
  width: 90px;
  margin-left: 10px;
  vertical-align: bottom;
}

.pictrue {
  width: 60px;
  height: 60px;
  border: 1px dotted rgba(0, 0, 0, 0.1);
  margin-right: 10px;
  position: relative;
  cursor: pointer;

  img {
    width: 100%;
    height: 100%;
  }

  video {
    width: 100%;
    height: 100%;
  }
}

.btndel {
  position: absolute;
  z-index: 1;
  width: 20px !important;
  height: 20px !important;
  left: 46px;
  top: -4px;
}

.labeltop {
  ::v-deep.el-form-item__label {
    float: none !important;
    display: inline-block !important;
    width: auto !important;
  }
}

.iview-video-style {
  width: 300px;
  height: 180px;
  border-radius: 10px;
  background-color: #707070;
  margin: 0 120px 20px;
  position: relative;
  overflow: hidden;
}

.iview-video-style .iconv {
  color: #fff;
  line-height: 180px;
  width: 50px;
  height: 50px;
  display: inherit;
  font-size: 26px;
  position: absolute;
  top: -74px;
  left: 50%;
  margin-left: -25px;
}

.iview-video-style .mark {
  position: absolute;
  width: 100%;
  height: 30px;
  top: 0;
  background-color: rgba(0, 0, 0, 0.5);
  text-align: center;
}
</style>
